_KPRCB

//0x5d80 bytes (sizeof) struct _KPRCB { ULONG MxCsr; //0x0 UCHAR LegacyNumber; //0x4 UCHAR ReservedMustBeZero; //0x5 UCHAR InterruptRequest; //0x6 UCHAR IdleHalt; //0x7 struct _KTHREAD* CurrentThread; //0x8 struct _KTHREAD* NextThread; //0x10 struct _KTHREAD* IdleThread; //0x18 UCHAR NestingLevel; //0x20 UCHAR ClockOwner; //0x21 union { UCHAR PendingTickFlags; //0x22 struct { UCHAR PendingTick:1; //0x22 UCHAR PendingBackupTick:1; //0x22 }; }; UCHAR PrcbPad00[1]; //0x23 ULONG Number; //0x24 ULONGLONG RspBase; //0x28 ULONGLONG PrcbLock; //0x30 CHAR* PriorityState; //0x38 struct _KPROCESSOR_STATE ProcessorState; //0x40 CHAR CpuType; //0x5f0 CHAR CpuID; //0x5f1 union { USHORT CpuStep; //0x5f2 struct { UCHAR CpuStepping; //0x5f2 UCHAR CpuModel; //0x5f3 }; }; ULONG MHz; //0x5f4 ULONGLONG HalReserved[8]; //0x5f8 USHORT MinorVersion; //0x638 USHORT MajorVersion; //0x63a UCHAR BuildType; //0x63c UCHAR CpuVendor; //0x63d UCHAR CoresPerPhysicalProcessor; //0x63e UCHAR LogicalProcessorsPerCore; //0x63f struct _KNODE* ParentNode; //0x640 ULONGLONG GroupSetMember; //0x648 UCHAR Group; //0x650 UCHAR GroupIndex; //0x651 UCHAR PrcbPad05[2]; //0x652 ULONG ApicMask; //0x654 ULONG CFlushSize; //0x658 VOID* AcpiReserved; //0x660 ULONG InitialApicId; //0x668 struct _KSPIN_LOCK_QUEUE LockQueue[17]; //0x670 struct _PP_LOOKASIDE_LIST PPLookasideList[16]; //0x780 struct _GENERAL_LOOKASIDE_POOL PPNxPagedLookasideList[32]; //0x880 struct _GENERAL_LOOKASIDE_POOL PPNPagedLookasideList[32]; //0x1480 struct _GENERAL_LOOKASIDE_POOL PPPagedLookasideList[32]; //0x2080 ULONGLONG PrcbPad20; //0x2c80 struct _SINGLE_LIST_ENTRY DeferredReadyListHead; //0x2c88 volatile LONG MmPageFaultCount; //0x2c90 volatile LONG MmCopyOnWriteCount; //0x2c94 volatile LONG MmTransitionCount; //0x2c98 volatile LONG MmDemandZeroCount; //0x2c9c volatile LONG MmPageReadCount; //0x2ca0 volatile LONG MmPageReadIoCount; //0x2ca4 volatile LONG MmDirtyPagesWriteCount; //0x2ca8 volatile LONG MmDirtyWriteIoCount; //0x2cac volatile LONG MmMappedPagesWriteCount; //0x2cb0 volatile LONG MmMappedWriteIoCount; //0x2cb4 ULONG KeSystemCalls; //0x2cb8 ULONG KeContextSwitches; //0x2cbc USHORT LdtSelector; //0x2cc0 USHORT PrcbPad40; //0x2cc2 ULONG CcFastReadNoWait; //0x2cc4 ULONG CcFastReadWait; //0x2cc8 ULONG CcFastReadNotPossible; //0x2ccc ULONG CcCopyReadNoWait; //0x2cd0 ULONG CcCopyReadWait; //0x2cd4 ULONG CcCopyReadNoWaitMiss; //0x2cd8 volatile LONG IoReadOperationCount; //0x2cdc volatile LONG IoWriteOperationCount; //0x2ce0 volatile LONG IoOtherOperationCount; //0x2ce4 union _LARGE_INTEGER IoReadTransferCount; //0x2ce8 union _LARGE_INTEGER IoWriteTransferCount; //0x2cf0 union _LARGE_INTEGER IoOtherTransferCount; //0x2cf8 volatile LONG PacketBarrier; //0x2d00 volatile LONG TargetCount; //0x2d04 volatile ULONG IpiFrozen; //0x2d08 VOID* IsrDpcStats; //0x2d10 ULONG DeviceInterrupts; //0x2d18 LONG LookasideIrpFloat; //0x2d1c ULONG InterruptLastCount; //0x2d20 ULONG InterruptRate; //0x2d24 ULONG PrcbPad41[22]; //0x2d28 struct _KDPC_DATA DpcData[2]; //0x2d80 VOID* DpcStack; //0x2dd0 LONG MaximumDpcQueueDepth; //0x2dd8 ULONG DpcRequestRate; //0x2ddc ULONG MinimumDpcRate; //0x2de0 ULONG DpcLastCount; //0x2de4 UCHAR ThreadDpcEnable; //0x2de8 volatile UCHAR QuantumEnd; //0x2de9 volatile UCHAR DpcRoutineActive; //0x2dea volatile UCHAR IdleSchedule; //0x2deb union { volatile LONG DpcRequestSummary; //0x2dec SHORT DpcRequestSlot[2]; //0x2dec struct { SHORT NormalDpcState; //0x2dec SHORT ThreadDpcState; //0x2dee }; struct { ULONG DpcNormalProcessingActive:1; //0x2dec ULONG DpcNormalProcessingRequested:1; //0x2dec ULONG DpcNormalThreadSignal:1; //0x2dec ULONG DpcNormalTimerExpiration:1; //0x2dec ULONG DpcNormalDpcPresent:1; //0x2dec ULONG DpcNormalLocalInterrupt:1; //0x2dec ULONG DpcNormalSpare:10; //0x2dec ULONG DpcThreadActive:1; //0x2dec ULONG DpcThreadRequested:1; //0x2dec ULONG DpcThreadSpare:14; //0x2dec }; }; ULONG LastTimerHand; //0x2df0 ULONG LastTick; //0x2df4 ULONG ClockInterrupts; //0x2df8 ULONG ReadyScanTick; //0x2dfc struct _KTIMER_TABLE TimerTable; //0x2e00 struct _KGATE DpcGate; //0x5000 VOID* PrcbPad52; //0x5018 struct _KDPC CallDpc; //0x5020 LONG ClockKeepAlive; //0x5060 UCHAR PrcbPad60[2]; //0x5064 USHORT NmiActive; //0x5066 LONG DpcWatchdogPeriod; //0x5068 LONG DpcWatchdogCount; //0x506c volatile LONG KeSpinLockOrdering; //0x5070 ULONG PrcbPad70[1]; //0x5074 VOID* CachedPtes; //0x5078 struct _LIST_ENTRY WaitListHead; //0x5080 ULONGLONG WaitLock; //0x5090 ULONG ReadySummary; //0x5098 LONG AffinitizedSelectionMask; //0x509c ULONG QueueIndex; //0x50a0 ULONG PrcbPad75[3]; //0x50a4 struct _KDPC TimerExpirationDpc; //0x50b0 struct _RTL_RB_TREE ScbQueue; //0x50f0 struct _LIST_ENTRY DispatcherReadyListHead[32]; //0x5100 ULONG InterruptCount; //0x5300 ULONG KernelTime; //0x5304 ULONG UserTime; //0x5308 ULONG DpcTime; //0x530c ULONG InterruptTime; //0x5310 ULONG AdjustDpcThreshold; //0x5314 UCHAR DebuggerSavedIRQL; //0x5318 UCHAR GroupSchedulingOverQuota; //0x5319 volatile UCHAR DeepSleep; //0x531a UCHAR PrcbPad80[1]; //0x531b ULONG ScbOffset; //0x531c ULONG DpcTimeCount; //0x5320 ULONG DpcTimeLimit; //0x5324 ULONG PeriodicCount; //0x5328 ULONG PeriodicBias; //0x532c ULONG AvailableTime; //0x5330 ULONG KeExceptionDispatchCount; //0x5334 ULONGLONG StartCycles; //0x5338 ULONGLONG GenerationTarget; //0x5340 ULONGLONG AffinitizedCycles; //0x5348 ULONGLONG PrcbPad81[2]; //0x5350 volatile LONG MmSpinLockOrdering; //0x5360 ULONG PageColor; //0x5364 ULONG NodeColor; //0x5368 ULONG NodeShiftedColor; //0x536c ULONG SecondaryColorMask; //0x5370 ULONG PrcbPad83; //0x5374 ULONGLONG CycleTime; //0x5378 ULONG CcFastMdlReadNoWait; //0x5380 ULONG CcFastMdlReadWait; //0x5384 ULONG CcFastMdlReadNotPossible; //0x5388 ULONG CcMapDataNoWait; //0x538c ULONG CcMapDataWait; //0x5390 ULONG CcPinMappedDataCount; //0x5394 ULONG CcPinReadNoWait; //0x5398 ULONG CcPinReadWait; //0x539c ULONG CcMdlReadNoWait; //0x53a0 ULONG CcMdlReadWait; //0x53a4 ULONG CcLazyWriteHotSpots; //0x53a8 ULONG CcLazyWriteIos; //0x53ac ULONG CcLazyWritePages; //0x53b0 ULONG CcDataFlushes; //0x53b4 ULONG CcDataPages; //0x53b8 ULONG CcLostDelayedWrites; //0x53bc ULONG CcFastReadResourceMiss; //0x53c0 ULONG CcCopyReadWaitMiss; //0x53c4 ULONG CcFastMdlReadResourceMiss; //0x53c8 ULONG CcMapDataNoWaitMiss; //0x53cc ULONG CcMapDataWaitMiss; //0x53d0 ULONG CcPinReadNoWaitMiss; //0x53d4 ULONG CcPinReadWaitMiss; //0x53d8 ULONG CcMdlReadNoWaitMiss; //0x53dc ULONG CcMdlReadWaitMiss; //0x53e0 ULONG CcReadAheadIos; //0x53e4 volatile LONG MmCacheTransitionCount; //0x53e8 volatile LONG MmCacheReadCount; //0x53ec volatile LONG MmCacheIoCount; //0x53f0 ULONG PrcbPad91[3]; //0x53f4 struct _PROCESSOR_POWER_STATE PowerState; //0x5400 struct _LIST_ENTRY ScbList; //0x55e0 ULONG PrcbPad92[19]; //0x55f0 ULONG KeAlignmentFixupCount; //0x563c struct _KDPC DpcWatchdogDpc; //0x5640 struct _KTIMER DpcWatchdogTimer; //0x5680 struct _CACHE_DESCRIPTOR Cache[5]; //0x56c0 ULONG CacheCount; //0x56fc volatile ULONG CachedCommit; //0x5700 volatile ULONG CachedResidentAvailable; //0x5704 VOID* HyperPte; //0x5708 VOID* WheaInfo; //0x5710 VOID* EtwSupport; //0x5718 union _SLIST_HEADER InterruptObjectPool; //0x5720 union _SLIST_HEADER HypercallPageList; //0x5730 VOID* HypercallPageVirtual; //0x5740 VOID* VirtualApicAssist; //0x5748 ULONGLONG* StatisticsPage; //0x5750 struct _KAFFINITY_EX PackageProcessorSet; //0x5758 ULONGLONG SharedReadyQueueMask; //0x5800 struct _KSHARED_READY_QUEUE* SharedReadyQueue; //0x5808 ULONGLONG CoreProcessorSet; //0x5810 ULONGLONG ScanSiblingMask; //0x5818 ULONGLONG LLCMask; //0x5820 ULONGLONG CacheProcessorMask[5]; //0x5828 ULONG ScanSiblingIndex; //0x5850 ULONG SharedReadyQueueOffset; //0x5854 struct _PROCESSOR_PROFILE_CONTROL_AREA* ProcessorProfileControlArea; //0x5858 VOID* ProfileEventIndexAddress; //0x5860 ULONGLONG PrcbPad94[3]; //0x5868 struct _SYNCH_COUNTERS SynchCounters; //0x5880 ULONGLONG PteBitCache; //0x5938 ULONG PteBitOffset; //0x5940 struct _FILESYSTEM_DISK_COUNTERS FsCounters; //0x5948 UCHAR VendorString[13]; //0x5958 UCHAR PrcbPad10[3]; //0x5965 ULONGLONG FeatureBits; //0x5968 ULONG PrcbPad11; //0x5970 union _LARGE_INTEGER UpdateSignature; //0x5978 struct _CONTEXT* Context; //0x5980 ULONG ContextFlagsInit; //0x5988 struct _XSAVE_AREA* ExtendedState; //0x5990 VOID* IsrStack; //0x5998 struct _KENTROPY_TIMING_STATE EntropyTimingState; //0x59a0 struct _SINGLE_LIST_ENTRY AbSelfIoBoostsList; //0x5af0 struct _SINGLE_LIST_ENTRY AbPropagateBoostsList; //0x5af8 struct _KDPC AbDpc; //0x5b00 struct _IOP_IRP_STACK_PROFILER IoIrpStackProfilerCurrent; //0x5b40 struct _IOP_IRP_STACK_PROFILER IoIrpStackProfilerPrevious; //0x5b94 struct _KTIMER_EXPIRATION_TRACE TimerExpirationTrace[16]; //0x5be8 ULONG TimerExpirationTraceCount; //0x5ce8 struct _REQUEST_MAILBOX* Mailbox; //0x5d00 struct _REQUEST_MAILBOX RequestMailbox[1]; //0x5d40 };